<?php

/**
 * @Project NUKEVIET 3.x
 * @Author VINADES.,JSC (contact@vinades.vn)
 * @Copyright (C) 2012 VINADES.,JSC. All rights reserved
 * @Createdate 2-1-2010 21:21
 */

if( ! defined( 'NV_IS_FILE_AUTHORS' ) ) die( 'Stop!!!' );

if( ! defined( 'NV_IS_SPADMIN' ) )
{
	Header( "Location: " . NV_BASE_ADMINURL . "index.php?" . NV_NAME_VARIABLE . "=" . $module_name );
	die();
}

$admin_id = $nv_Request->get_int( 'admin_id', 'get', 0 );

if( empty( $admin_id ) or $admin_id == $admin_info['admin_id'] )
{
	Header( "Location: " . NV_BASE_ADMINURL . "index.php?" . NV_NAME_VARIABLE . "=" . $module_name );
	die();
}
$sql = "SELECT * FROM `" . NV_AUTHORS_GLOBALTABLE . "` WHERE `admin_id`=" . intval( $admin_id );
$result = $db->sql_query( $sql );
$numrows = $db->sql_numrows( $result );
if( empty( $numrows ) )
{
	Header( "Location: " . NV_BASE_ADMINURL . "index.php?" . NV_NAME_VARIABLE . "=" . $module_name );
	die();
}

$row = $db->sql_fetchrow( $result );

if( $row['lev'] == 1 or ( ! defined( "NV_IS_GODADMIN" ) and $row['lev'] == 2 ) )
{
	Header( "Location: " . NV_BASE_ADMINURL . "index.php?" . NV_NAME_VARIABLE . "=" . $module_name );
	die();
}

$row_user = $db->sql_fetchrow( $db->sql_query( "SELECT * FROM `" . NV_USERS_GLOBALTABLE . "` WHERE `userid`=" . $admin_id . "" ) );
$susp_reason = array();
$last_reason = array();

if( ! empty( $row['susp_reason'] ) )
{
	$susp_reason = unserialize( $row['susp_reason'] );
	$last_reason = ( ! empty( $susp_reason ) ) ? $susp_reason[0] : "";
}

$old_suspend = intval( $row['is_suspend'] );

if( empty( $old_suspend ) )
{
	$allow_change = true;
}
else
{
	$allow_change = ( defined( "NV_IS_GODADMIN" ) ) ? true : ( ( defined( "NV_IS_SPADMIN" ) and $last_reason['start_admin'] == $admin_info['login'] and $global_config['spadmin_add_admin'] == 1 ) ? true : false );
}

$contents = array();
$contents['change_suspend'] = array();
if( $allow_change )
{
	$new_suspend = ( $old_suspend ) ? 0 : 1;

	$error = "";
	if( $nv_Request->get_int( 'save', 'post', 0 ) )
	{
		$new_reason = ( ! empty( $new_suspend ) ) ? filter_text_input( 'new_reason', 'post', '', 1 ) : "";
		$sendmail = $nv_Request->get_int( 'sendmail', 'post', 0 );
		$clean_history = defined( "NV_IS_GODADMIN" ) ? $nv_Request->get_int( 'clean_history', 'post', 0 ) : 0;
		
		if( ! empty( $new_suspend ) and empty( $new_reason ) )
		{
			$error = sprintf( $lang_module['susp_reason_empty'], $row_user['username'] );
		}
		else
		{
			if( $new_suspend )
			{
				if( $clean_history )
				{
					$susp_reason = array();
					$susp_reason[] = array(
						'starttime' => NV_CURRENTTIME,
						'endtime' => 0,
						'start_admin' => $admin_info['admin_id'],
						'end_admin' => '',
						'info' => $new_reason
					);
				}
				else
				{
					array_unshift( $susp_reason, array(
						'starttime' => NV_CURRENTTIME,
						'endtime' => 0,
						'start_admin' => $admin_info['admin_id'],
						'end_admin' => '',
						'info' => $new_reason 
					) );
				}
			}
			else
			{
				if( $clean_history )
				{
					$susp_reason = array();
				}
				else
				{
					$susp_reason[0] = array(
						'starttime' => $last_reason['starttime'],
						'endtime' => NV_CURRENTTIME,
						'start_admin' => $last_reason['start_admin'],
						'end_admin' => $admin_info['admin_id'],
						'info' => $last_reason['info']
					);
				}
			}
			$sql = "UPDATE `" . NV_AUTHORS_GLOBALTABLE . "` SET `edittime`=" . NV_CURRENTTIME . ",  `is_suspend`=" . $new_suspend . ", `susp_reason`=" . $db->dbescape( serialize( $susp_reason ) ) . " WHERE `admin_id`=" . $admin_id;
			if( $db->sql_query( $sql ) )
			{
				nv_insert_logs( NV_LANG_DATA, $module_name, $lang_module['suspend' . $new_suspend] . " ", " Username : " . $row_user['username'], $admin_info['userid'] );
				if( ! empty( $sendmail ) )
				{
					$title = sprintf( $lang_module['suspend_sendmail_title'], $global_config['site_name'] );
					$my_sig = ( ! empty( $admin_info['sig'] ) ) ? $admin_info['sig'] : "All the best";
					$my_mail = $admin_info['view_mail'] ? $admin_info['email'] : $global_config['site_email'];
					
					if( $new_suspend )
					{
						$message = sprintf( $lang_module['suspend_sendmail_mess1'], $global_config['site_name'], nv_date( "d/m/Y H:i", NV_CURRENTTIME ), $new_reason, $my_mail );
					}
					else
					{
						$message = sprintf( $lang_module['suspend_sendmail_mess0'], $global_config['site_name'], nv_date( "d/m/Y H:i", NV_CURRENTTIME ), $last_reason['info'] );
					}

					$message = trim( $message );

					$mess = $message;
					$mess .= "\r\n\r\n............................\r\n\r\n";
					$mess .= nv_EncString( $message );

					$mess = nv_nl2br( $mess, "<br />" );

					$xtpl = new XTemplate( "message.tpl", NV_ROOTDIR . "/themes/" . $global_config['module_theme'] . "/system" );
					$xtpl->assign( 'SITE_CHARSET', $global_config['site_charset'] );
					$xtpl->assign( 'SITE_NAME', $global_config['site_name'] );
					$xtpl->assign( 'SITE_SLOGAN', $global_config['site_description'] );
					$xtpl->assign( 'SITE_EMAIL', $global_config['site_email'] );
					$xtpl->assign( 'SITE_FONE', $global_config['site_phone'] );
					$xtpl->assign( 'SITE_URL', $global_config['site_url'] );
					$xtpl->assign( 'TITLE', $title );
					$xtpl->assign( 'CONTENT', $mess );
					$xtpl->assign( 'AUTHOR_SIG', $my_sig );
					$xtpl->assign( 'AUTHOR_NAME', $admin_info['username'] );
					$xtpl->assign( 'AUTHOR_POS', $admin_info['position'] );
					$xtpl->assign( 'AUTHOR_EMAIL', $my_mail );
					$xtpl->parse( 'main' );
					
					$content = $xtpl->text( 'main' );
					$from = array( $admin_info['username'], $my_mail );
					$to = $row_user['email'];
					$send = nv_sendmail( $from, $to, nv_EncString( $title ), $content );
					
					if( ! $send )
					{
						nv_info_die( $lang_global['error_info_caption'], $lang_global['site_info'], $lang_global['error_sendmail_admin'], 1 );
					}
				}
			}
			Header( "Location: " . NV_BASE_ADMINURL . "index.php?" . NV_NAME_VARIABLE . "=" . $module_name . "&" . NV_OP_VARIABLE . "=suspend&id=" . $id );
		}
	}
	else
	{
		$adminpass = $new_reason = "";
		$clean_history = $sendmail = 0;
	}

	$contents['change_suspend']['new_suspend_caption'] = ( ! empty( $error ) ) ? $error : $lang_module['chg_is_suspend' . $new_suspend];
	$contents['change_suspend']['new_suspend_is_error'] = ( ! empty( $error ) ) ? 1 : 0;
	$contents['change_suspend']['new_suspend_action'] = NV_BASE_ADMINURL . "index.php?" . NV_NAME_VARIABLE . "=" . $module_name . "&amp;" . NV_OP_VARIABLE . "=suspend&amp;admin_id=" . $admin_id;
	$contents['change_suspend']['sendmail'] = array( $lang_module['suspend_sendmail'], $sendmail );
	
	if( ! empty( $new_suspend ) )
	{
		$contents['change_suspend']['new_reason'] = array(
			$lang_module['suspend_reason'],
			$new_reason,
			255 );
	}
	if( defined( "NV_IS_GODADMIN" ) )
	{
		if( ( $new_suspend and ! empty( $susp_reason ) ) or ( empty( $new_suspend ) and sizeof( $susp_reason ) >= 1 ) )
		{
			$contents['change_suspend']['clean_history'] = array( $lang_module['clean_history'], $clean_history );
		}
	}
	$contents['change_suspend']['submit'] = $lang_module['suspend' . $new_suspend];
}

if( empty( $susp_reason ) )
{
	$contents['suspend_info'] = array( sprintf( $lang_module['suspend_info_empty'], $row_user['username'] ), array() );

}
else
{
	$inf = array();
	$ads = array();
	
	foreach( $susp_reason as $vals )
	{
		$ads[] = $vals['start_admin'];
		if( ! empty( $vals['end_admin'] ) ) $ads[] = $vals['end_admin'];
	}
	
	$ads = array_unique( $ads );
	$ads = "'" . implode( "','", $ads ) . "'";
	$query2 = "SELECT `userid`, `username`, `full_name` FROM `" . NV_USERS_GLOBALTABLE . "` WHERE `userid` IN (" . $ads . ")";
	$result2 = $db->sql_query( $query2 );
	
	$ads = array();
	while( $row2 = $db->sql_fetchrow( $result2 ) )
	{
		$ads[$row2['userid']] = "<a href=\"" . NV_BASE_ADMINURL . "index.php?" . NV_NAME_VARIABLE . "=" . $module_name . "&amp;admin_id=" . $row2['userid'] . "\">" . $row2['full_name'] . "</a>";
	}
	$db->sql_freeresult( $query2 );

	foreach( $susp_reason as $vals )
	{
		$start = sprintf( $lang_module['suspend_info'], nv_date( "d/m/Y H:i", $vals['starttime'] ), $ads[$vals['start_admin']] );
		$end = "";
		if( ! empty( $vals['endtime'] ) )
		{
			$end = sprintf( $lang_module['suspend_info'], nv_date( "d/m/Y H:i", $vals['endtime'] ), $ads[$vals['end_admin']] );
		}
		$inf[] = array(
			$start,
			$end,
			$vals['info']
		);
	}

	$contents['suspend_info'] = array(
		sprintf( $lang_module['suspend_info_yes'], $row_user['username'] ),
		$inf,
		$lang_module['suspend_start'],
		$lang_module['suspend_end'],
		$lang_module['suspend_reason']
	);
}

$page_title = sprintf( $lang_module['nv_admin_chg_suspend'], $row_user['username'] );

// Parse content
$xtpl = new XTemplate( "suspend.tpl", NV_ROOTDIR . "/themes/" . $global_config['module_theme'] . "/modules/" . $module_file );
$xtpl->assign( 'SUSPEND_INFO', $contents['suspend_info'][0] );

if( empty( $contents['suspend_info'][1] ) )
{
	$xtpl->parse( 'suspend.suspend_info' );
}
else
{
	$xtpl->assign( 'SUSPEND_INFO2', $contents['suspend_info'][2] );
	$xtpl->assign( 'SUSPEND_INFO3', $contents['suspend_info'][3] );
	$xtpl->assign( 'SUSPEND_INFO4', $contents['suspend_info'][4] );
	
	$a = 0;
	foreach( $contents['suspend_info'][1] as $value )
	{
		$xtpl->assign( 'CLASS', ( $a % 2 ) ? " class=\"second\"" : "" );
		$xtpl->assign( 'VALUE0', $value[0] );
		$xtpl->assign( 'VALUE1', $value[1] );
		$xtpl->assign( 'VALUE2', $value[2] );
		$xtpl->parse( 'suspend.suspend_info1.loop' );
		++$a;
	}
	$xtpl->parse( 'suspend.suspend_info1' );
}

if( ! empty( $contents['change_suspend'] ) )
{
	$class = ( $contents['change_suspend']['new_suspend_is_error'] ) ? " class=\"error\"" : "";
	$xtpl->assign( 'CLASS', ( $contents['change_suspend']['new_suspend_is_error'] ) ? " class=\"error\"" : "" );
	$xtpl->assign( 'NEW_SUSPEND_CAPTION', $contents['change_suspend']['new_suspend_caption'] );
	$xtpl->assign( 'ACTION', $contents['change_suspend']['new_suspend_action'] );

	if( ! empty( $contents['change_suspend']['new_reason'] ) )
	{
		$xtpl->assign( 'NEW_REASON0', $contents['change_suspend']['new_reason'][0] );
		$xtpl->assign( 'NEW_REASON1', $contents['change_suspend']['new_reason'][1] );
		$xtpl->assign( 'NEW_REASON2', $contents['change_suspend']['new_reason'][2] );
		$xtpl->parse( 'suspend.change_suspend.new_reason' );
	}

	$xtpl->assign( 'SENDMAIL', $contents['change_suspend']['sendmail'][0] );
	$xtpl->assign( 'CHECKED', $contents['change_suspend']['sendmail'][1] ? " checked=\"checked\"" : "" );

	if( ! empty( $contents['change_suspend']['clean_history'] ) )
	{
		$xtpl->assign( 'CLEAN_HISTORY', $contents['change_suspend']['clean_history'][0] );
		$xtpl->assign( 'CHECKED1', $contents['change_suspend']['clean_history'][1] ? " checked=\"checked\"" : "" );
		$xtpl->parse( 'suspend.change_suspend.clean_history' );
	}
	
	$xtpl->assign( 'SUBMIT', $contents['change_suspend']['submit'] );
	$xtpl->parse( 'suspend.change_suspend' );
}

$xtpl->parse( 'suspend' );
$contents = $xtpl->text( 'suspend' );

include ( NV_ROOTDIR . "/includes/header.php" );
echo nv_admin_theme( $contents );
include ( NV_ROOTDIR . "/includes/footer.php" );

?>